package com.zhengb.algorithmdemo.basic.sort;

import java.util.Arrays;

/**
 * 选择排序
 * Created by zhengbo on 2020/2/25.
 */
public class SelectionSort {

    /**
     * 最坏情况时间复杂度O(N2)
     * 最坏情况时间复杂度O(N)
     * 平均情况下事件复杂度O(N2)
     * 最坏情况下空间复杂度(O1)
     *
     * @param array
     */
    public static void selectionSort(int[] array) {

        int i, j, min, temp;

        for (i = 0; i < array.length; i++) {
            min = i;

            for (j = i + 1; j < array.length; j++) {
                if (array[j] < array[min]) {
                    min = j;
                }

                temp = array[min];
                array[min] = array[i];

                array[i] = temp;
            }
        }
    }

    public static void main(String[] args) {

        int[] array = new int[]{3, 5, 7, 4, 2, 9, 10};

        selectionSort(array);

        System.out.println(Arrays.toString(array));
    }
}
